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Background 

In a system of networked computers, a computer communicates with other 
computers in the network via a data link or medium. The interface between the medium 
and the computer is often referred to as a network controller. The network controller 
interprets data from the computer and modulates an electromagnetic wave that is 
propagated on the medium in response to the data, and also receives and demodulates 
electromagnetic waves propagating on the medium in order to provide received data to 
the computer. 

Within the context of the OSI (Open Systems Interconnection) layered 
communication model of the ISO (International Standards Organization), a network 
controller provides the function of a DLC (Data Link Control) and a PHY (Physical 
layer). A standard for a popular network and medium is defined in EEEE (Institute of 
Electrical and Electronic Engineers) standard 802.3, commonly referred to as Ethernet. 
Ethernet further divides the DLC so that it includes a MAC (Medium Access Control) 
sublayer. 

In the past, a network controller usually comprised a set of semiconductor 
components residing on a card. However, with the number of transistors on a die 
increasing, the level of integration is also increasing. As a result, the MAC usually 
associated with a network controller may be integrated with the chipset of a personal 
computer. With such an arrangement, the PHY may be supplied separately by 
manufacturers other than the manufacturer of the chipset. Consequently, it is desirable 
that the interface between a MAC and PHY be flexible enough so that PHYs from 
different manufacturers, with possibly different numbers of pin counts and data link 
speeds, may be connected to the MAC. It is also desirable that the pin count for such an 
interface be kept as small as possible without sacrificing flexibility and future 
requirements. 

Brief Description of the Drawings 

Fig. 1 illustrates a computer system employing an embodiment of the present 
invention. 

Fig. 2 illustrates the format of PHY-to-MAC control words according to an 
embodiment of the present invention. 
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Fig. 3 illustrates the format of a slow speed mode PHY-to-MAC data word 
according to an embodiment of the present invention. 

Fig. 4 illustrates the format of an equal speed mode PHY-to-MAC data word 
according to an embodiment of the present invention. 

Fig. 5 illustrates the format of a PHY-to-MAC word having no receive data 
according to an embodiment of the present invention. 

Fig. 6 illustrates the format of a MAC-to-PHY word according to an embodiment 
of the present invention. 

Fig. 7 illustrates the value of two word fields for a register write according to an 
embodiment of the present invention. 

Fig. 8 illustrates the value of two word fields for a register read according to an 
embodiment of the present invention. 

Fig. 9 is an exemplary embodiment of a MAC/PHY interface having two active 
receive and two active transmit ports. 

Fig. 10 is an exemplary embodiment of a circuit to determine the number of 
active ports in a MAC/PHY interface. 

Fig. 1 1 is an exemplary embodiment of a circuit to determine the number of 
PHYs connected to a MAC. 

Fig. 12a is an exemplary embodiment of circuit for generating a Reset/Sync signal 
from a Reset signal and a Sync signal. 

Fig. 12b is an exemplary embodiment of a circuit for separating the Reset and 
Sync signals from the Reset/Sync signal. 

Description of Embodiments 

A computer system utilizing embodiments of the present invention is shown in 
Fig. 1. The computer system of Fig. 1 comprises CPU (Central Processing Unit) 102, but 
a multi-processor system utilizing embodiments of the present invention may also be 
realized. Various architectures may be employed for CPU 102 to communicate with 
system memory 104 and other components of the computer system. In the embodiment of 
Fig. 1, MCH (Memory Controller Hub) 106 is integrated within CPU 102 and serves as a 
memory controller for system memory 104 and an interface to hublink 108. Hublink 108 
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provides for communication between CPU 102 and other components, and it may be part 
of a larger I/O system and switch. A bus may be employed instead of hublink 108. 

Bus interface 110 provides an interface between hublink 108, BIOS (Basic Input 
Output System) memory 112, and bus 114. BIOS memory 112 may be non-volatile 
5 memory, such as an EEPROM (Electrically Erasable Programmable Read Only 

Memory). Bus 114 may be, for example, a PCI (Peripheral Component Interconnect) bus. 
See PCI Special Interest Group, www.pcisig.com. Various PCI devices, such as PCI 
device 116, may be connected to bus 114. 

Connected to bus 114 is host interface 118 to provide an interface to FIFO (First- 
10 In-First-Out) buffer, which is connected to MAC unit 124. MAC 124 provides a medium 
access control function for communication across data link (medium) 128, and may, for 
example, implement the Ethernet protocol. Host interface 118 may also access 
nonvolatile memory, such as EEPROM 120. 

PHY unit 126 performs modulation and coding of the digital signals provided by 
15 MAC 124, thereby providing an electromagnetic signal to be propagated along data link 
128. PHY 126 also performs demodulation and decoding of received signals on data link 
128. Data link 128 may be a bus, or a point-to-point link. 

For one embodiment, components 110, 118, 122, and 124 comprise chipset 130, 
and PHY 126 is a distinct device from chipset 130. MAC 124 and PHY 126 communicate 
20 with each other through interface 132. Embodiments of the present invention provide for 
a cost-effective, flexible interface between MAC 124 and PHY 126. 

Communication of data across interface 132 is word based. PHY 126 transmits a 
word to MAC 124 via wires RxD 134 and MAC 124 transmits a word to PHY 126 via 
wires TxD 136. Words that are transmitted from PHY 126 to MAC 124 are referred to as 
25 PtM (PHY-to-MAC) words, and words that are transmitted from MAC 124 to PHY 126 
are referred to as MtP (MAC-to-PHY) words. The PtM and MtP words are synchronized 
with each other and with a clock signal propagating on wire CLK 138. Interface 132 also 
comprises Reset/Sync 139. 

For one embodiment, the word lengths of the MtP and PtM words are equal to 
30 each other, and the number of wires making up RxD 134 and TxD 136 are equal to each 
other and is a divisor of the word length of the PtM and MtP words. If the number of 
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wires making up RxD 134 and TxD 136 are less than the word lengths of the PtM and 
MtP words, then the fields making up the PtM and MtP words are time multiplexed over 
the respective RxD 134 and TxD 136 pins. 

For one embodiment, the formats for PtM words are provided in Figs. 2, 3, 4, and 
5 5, and the formats for MtP words are provided in Fig. 6. The most significant bit (field) 
position of PtM words (bit position number 1 1) is the Rx DV (Receive Data Valid) field. 
Rx_DV indicates whether there is a valid data frame being transmitted by PHY 126 to 
MAC 124. For the particular embodiment of Fig. 2, Rx_DV = 0 indicates that there is not 
a data frame in progress. If Rx DV = 0, then the PtM words provide control information 
10 between PHY 126 and MAC 124. In the particular embodiment of Fig. 2, this control 
information is provided by the three control words indicated as words 0, 1, and 2 in Fig. 
2. 

Bit position number 9 in Fig. 2 is the Tx_Cyc (Transmit Cycle) field to indicate 
whether MAC 124 is requested by PHY 126 to send data in the next MtP word. For the 

15 particular embodiment of Fig. 2, Tx_Cyc = 1 indicates that PHY 126 is ready for data 
from MAC 124, whereas Tx_Cyc = 0 indicates that PHY 126 is not ready for data from 
MAC 124. In this way, various data link speeds may be supported without changing the 
clock signal frequency on CLK 138. Also, the transmit and receive speeds may be 
different. Furthermore, even when there is no frame in progress, the TxCyc field may be 

20 used by PHY 126 to communicate to MAC 124 the data link speed. 

Bit position number 8 in Fig. 2 is the Mdout (Management Frames Protocol Data 
Out) field. Mdout provides a data bit that MAC 124 reads from a register in PHY 126. To 
read multiple data bits from a register in PHY 126, multiple PtM words are used, each 
PtM word providing a single data bit. The Mdout field is described in more detail later in 

25 connection with a Management Frames Protocol and the Mdstart and Mdin fields of Fig. 
6. 

Bit positions 7 and 6 indicate which PtM format is used. In the embodiment of 
Fig. 2, "00", "01", and "10" in bits positions 7 and 6 indicate, respectively, words 0, 1, 
and 2. 

30 For the word 0 format, bit position number 5 is the PtM_mode (PHY to MAC 

Mode) field. The PtM_mode indicates the mode of the PtM data word that is used to 
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transmit received data from PHY 126 to MAC 124. In the particular embodiment of 
Figs. 3 and 4, a Slow mode PtM data word is shown in Fig. 3 and an Equal Speed mode 
PtM data word is shown in Fig. 4. MtP data words are indicated if Rx DV = 1 and 
Rx Cyc (Receive Cycle) = 1, as seen in Fig. 3 and 4. 
5 The Equal Speed mode is used if the interface speed and MtP word formats are 

such that MAC 124 is able to transfer data to PHY 126 at the same data rate as PHY 126 
is able to transmit on the medium. In the Equal Speed mode, the PtM data word shown in 
Fig. 4 does not have a Tx Cyc field because PHY 126 is able to receive a data word from 
MAC 124 at the same rate that MAC 124 can provide data words. For the Slow mode, the 
10 data rate at which PHY 126 can transmit on the medium is less than the rate at which 
MAC 124 can generate data. Consequently the Tx_Cyc field (bit position 9 in Fig. 3) is 
used in the Slow mode PtM data word because PHY 126 is not always ready to receive 
;2 data from MAC 124. 

=F Bit position number 4 in word 0 of Fig. 2 is the Even field. For each frame of data 

Ua 15 received, only those frames with 8 bits of valid data are to be used. It may happen that for 

some received frames, there are less than 8 bits of data. For these frames, the Even field 
0 is set. 

l„ J: For word 1 in Fig. 2, bit position number 5 is the RST_RQST (Reset Request) 

; Jt field. This field indicates whether PHY 126 requests that MAC 124 send a reset signal to 

ill 20 PHY 126. Bit position number 4 in word 1 is the SQL (Squelch) field. The SQL field 
.*5 indicates whether another device is connected to the medium to which PHY 126 is 

connected to, and may be used for power management. For word 2 in Fig. 2, the present 
embodiment does not specify the fields for bit positions 5 and 4, which are reserved for 
future developments. 

25 Bit position number 3 for the PtM words in Fig. 2 is the CRS (Carrier sense 

Signal) field, which indicates whether a carrier signal on the medium is sensed by PHY 
126 

Bit position numbers 2, 1, and 0 for word 0 of Fig. 2 constitute the RxEr 
(Received Error) field, which serves as an error detection flag for the previously received 
30 frame. Rx_Er = 000 indicates that no error has been detected in a frame. 
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For word 1 of Fig, 2, bit position number 2 is the Duplex field, which indicates 
whether PHY 126 provides foil-duplex or half-duplex communication. Bit position 
number 1 is the Speed field. PHY 126 may support two different speeds, e.g., lOMbit/sec 
and lOOMbit/sec, or lOMbit/sec and 1 Mbit/sec. MAC 124 does not need to be aware of 
5 the speed of operation, but it needs to be able to report fast or slow speeds. The Speed 
field is used by MAC when generating such status information. Bit position number 0 is 
the IJEr (Interface Error) field, which indicates whether there is an error in interface 132. 

For word 2 of Fig. 2, bit position 2 is not specified and is reserved for future 
developments. Bit position number 1 is the Link field, which indicates whether the data 
10 link is alive. Bit position number 0 is the Int-Rqst (Interrupt Request) field, which allows 
PHY 126 to request that MAC 124 generate a software interrupt. 

If both Rx_Dv =1 and Rx_Cyc = 1, then a PtM word has either the Slow mode 
format of Fig. 3 or the Equal Speed format of Fig. 4. As described earlier, an Equal 
Speed format PtM word does not require the TxCyc field. Bit position number 9 of an 
15 Equal Speed format word is the Mdout field, whereas bit position number 9 of the Slow 
mode format word is the TxCyc field. Consequently, an Equal Speed format PtM data 
word may also provide register reads of PHY 126. Bit positions 0 through 8 of Slow and 
Equal Speed mode PtM words provide 8 bits of received data as well as the CRS field, as 
shown in Figs. 3 and 4. 

20 For the PtM word format illustrated in Fig. 5, Rx_Dv = 1 and Rx_Cyc = 0. In this 

case, the word may have data from register reads in the Mdout field in bit position 8, but 
in the particular embodiment illustrated there are no received data bits to read. Bit 
position number 9 is the Tx_Cyc field. The format of Fig. 5 applies to either the Slow 
mode or Equal Speed mode. Bit positions 4 through 7 and 0 through 2 are reserved, and 

25 bit position number 3 provides the CRS field. 

Fig. 6 illustrates formats for MtP words according to an embodiment. The most 
significant bit of a MtP word is the SEL field. The particular format for SEL = 1 is not 
specified in the present embodiment, and the MtP word in this case may provide for 
various commands as indicated in Fig. 6. For SEL = 0, the rest of the bit positions are 

30 indicated as shown in Fig. 6, and are described below in connection with the earlier 
mentioned Management Frames Protocol. 
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Bit position number 10 is the Mdstart (Management Frames Protocol Frame Start) 
field and bit position number 9 is the Mdin (Management Frames Protocol Frame In) 
field. The Mdstart field indicates to PHY 126 that MAC 124 is to perform a register read 
or write to PHY 126. In the particular embodiment of Fig. 6, Mdstart = 1 indicates that 
5 MAC 124 is to perform a register read or write. The Mdin field indicates whether the 
register operation is a read or write. The values for the Mdin field for a register write are 
indicated in Fig. 7, and the values for the Mdin field for a register read are indicated in 
Fig. 8. As seen in Fig. 7, the Mdin field also provides the register address and data. Figs. 
7 and 8 also indicate the values of the Mdout field for register reads and writes. The time 

10 direction for Figs. 7 and 8 is from left to right. 

For a register write, Mdout is held IDLE. For one embodiment, IDLE is either at 0 
or 1, that is, the corresponding pin is not tri-stated when in the IDLE mode. Mdin is held 
IDLE for some period of time until Mdstart = 1. For the particular embodiment of Fig. 7, 
Mdin has the value 0 when held IDLE. When Mdstart = 1, Mdin is set to some value ST 

15 (Start), which for the embodiment of Fig. 7 is indicated as a value of 1 . The next two bit 
values for Mdin are denoted by OP, which is the particular operation to be performed. 
For the embodiment of Fig. 7, OP = 01 indicates that a register write is to be performed. 
The next 10 bit values for Mdin constitute the address of the register to be read, and the 
next 16 bit values of Mdin constitute the data to be written. 

20 As seen in the embodiment of Fig. 8, for a register read OP = 10. After the 10 bits 

of the address of the register to be read are provided by Mdin, there is a wait time in 
which Mdin takes on the four bit values 0001 . This wait time gives PHY 126 time to 
prepare the data to be read. Mdout is held at IDLE, followed by a wait time, and then 
followed by the 16 bit data value to be read. 

25 It is seen that the word formats in Figs. 2 through 6, and the bit values for Mdin 

and Mdout as shown in Figs, 7 and 8, provide a mechanism for a nested serial interface 
between PHY 126 and MAC 124, so that register reads and writes may be accomplished 
with only one pin. Such register transactions us multiple transmissions of words across 
interface 132. 

30 Returning to Fig. 6, bit position number 8 is the Tx_EN (Transmit Enable) field. 

For Tx EN = 1, the next 8 bits of the MtP word is the data octet provided by MAC 124 to 
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PHY 126 for transmission over the data link. For Tx_EN = 0, bit position numbers 4, 5, 
6, and 7 are reserved, bit position 3 is the PHY_PD (PHY Power Down) field, bit 
position number 2 is the Lpbk (Loop Back) field, bit position number 1 is the LED_SEL 
(Light Emitting Diode Select) field, and bit position number 0 is the Rx_addr_match 
5 (Address Match Field). The PHY_PD field indicates whether PHY 126 is requested to go 
into a power down mode, and is also used to wake up PHY 126 once it has been powered 
down. The Lpbk field indicates whether PHY 126 is to perform a loopback for 
debugging, where in a loopback mode PHY 126 sends on RxD 134 the word received on 
TxD 136 without transmitting the word. The LED SEL field indicates to PHY 126 a 
10 LED mode to use. The Rxaddrmatch field indicates whether there is an address match 
for a frame received on data link 128. 

A word based communication protocol between a MAC and a PHY, such as 
^ described above, facilitates in an interface in which the number of active pins making up 

«F the interface varies according to the type of PHY connected to the MAC. This allows a 

U 1 5 MAC to be designed with some fixed number of pins or contacts, but which may be 
^ connected to PHYs having varying pin or contact counts. The term port will also be used 

□ to indicate a pin or contact, or their equivalents. 

''U For example, in Fig. 9 MAC 124 is connected to PHY 126 via CLK 138, 

[Jj Reset/Sync 139, RxD lines RxDO 902 and RxDl 904, and TxD lines TxDO 906 and 

lij 20 TxDl 908. MAC 124 has the capacity for additional RxD and TxD lines, as indicated by 
% ports RxD2 910, RxD3 912, TxD2 914, and TxD3 916, but these ports are not connected 

to PHY 126 because PHY 126 does not support these ports. 

During a reset signal propagated on Reset/Sync 139, MAC 124 determines which 
RxD and TxD ports are connected to PHY 126. Because the number of active RxD ports 
25 are equal to the number of active TxD ports, MAC 124 needs only to determine the 
number of active RxD ports. An embodiment for determining active RxD ports is 
illustrated in Fig. 10. For simplicity, only one RxD pin or contact, RxDi 1002, is shown 
for MAC 124 and only one RxD pin or contact, RxDj 1004, is shown for PHY 126. MAC 
124 has pullup pMOSFET (p-Metal Oxide Semiconductor Field Effect Transistor) 1006 
30 and PHY 126 has pulldown nMOSFET 1008. Other pulldown and pullup circuits may be 
used in different embodiments. Pullup 100 and pulldown 1008 are designed so that pullup 
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1006 is weak compared to pulldown 1008. That is, if / =y so that RxDi and RxDj are 
connected together, then the pullup and pulldowns are sized such that RxDi is pulled 
down to ground (i.e., some common potential such as a substrate potential) if both 
pulldowns and pullup s are ON. 
5 Pulldown 1008 turns ON when Reset goes HIGH. Pullup 1006 is controlled by 

FSM (Finite State Machine) 1010 which is responsive to the Reset signal. When Reset 
goes HIGH, pullup 1006 is turned ON by FSM 1010 and the output of input buffer 1012 
is sampled by FSM 1010 after some time interval. If the output of input buffer 1012 is 
sensed HIGH, then FSM 1010 determines that RxDi 1002 is not connected, in which case 

1 0 the output of input buffer 1012 is not strobed. If, however, the output of input buffer 1012 
is sensed LOW, then FSM 1010 determines that RxDi 1002 is connected to PHY 126, in 
which case the output of input buffer 1012 is strobed every clock cycle to provide 
communication between MAC 124 and PHY 126. 

Other embodiments provide for the determination of the active pins as well as the 

15 number of PHYs connected to MAC 124. An embodiment is illustrated in Fig. 1 1, where 
connected to MAC 1102 are PHY1 1104 and PHY2 1106. There are two clock signal 
lines, CLK1 1108 and CLK2 1110, and two Reset/Sync lines, Reset/Syncl 1112 and 
Reset/Sync2 1114. PHY1 1104 has connections for only two receive data lines and two 
transmit data lines, whereas PHY2 1106 has connections for four data receive lines and 

20 four data transmit lines. 

Because each PHY provides its own clock signal, the number of PHYs connected 
to MAC 124 is determined by sensing the number of clock signal lines. Although not 
shown, pulldowns, finite state machines, input buffers, and pullups are provided in Fig. 
1 1 as shown in Fig. 10. A clock signal is sensed by keeping Reset HIGH for some 

25 predetermined number of clock cycles, and sampling the output of the input buffers to 
determine if there is a clock signal. Determining the clock signal lines provides the 
number of connected PHYs, as well as the beginning of the receive data lines for each 
connected PHY. The number of active pins may be determined as described for Fig. 10. 
For the embodiment shown in Fig. 1, Reset/Sync wire 139 provides a combination 

30 of a Reset signal and a Sync signal. The Reset signal clears registers (not shown) in PHY 
126. The Sync signal for PHY 126 provides word synchronization. The Sync signal is 
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synchronized with the clock signal of PHY 126 and has the same duty cycle. The Sync 
signal is introduced in addition to the clock signal so as to provide immunity to noise 
spikes on the clock signal, so that PtM and MtP words are assured of being properly 
aligned. The Reset is asserted asynchronously with the clock signal of PHY 126, but is 
5 de-asserted synchronously. The Reset signal is asserted for a longer interval of time than 
a clock cycle, e.g., the minimum assertion time is two clock cycles. 

The Reset/Sync signal is generated from the Reset and Sync signals by providing 
the logical OR of the Reset and Sync signals, as shown in Fig. 12a using logic OR gate 
1202. If the Reset signal is LOW, then the Reset/Sync signal is the same as the Sync 
10 signal, whereas when the Reset signal is HIGH, then the Reset/Sync signal is the same as 
the Reset signal because the Reset signal is longer in duration than the period of the Sync 
signal. 

Fig. 12b provides an embodiment for decoding, or separating, the Reset and Sync 
signals from the Reset/Sync signal D flip-flops 1204 and 1206 are clocked by the CLK 

15 (clock) signal provided by PHY 126, so that when the CLK signal is present, the signals 
at nodes 1210 and 1212 are, respectively, one unit and two unit delayed samples of the 
Reset/Sync signal at node 1214, where one unit is equal to one period of the CLK signal. 
PHY 126 provides the CLK signal when it is powered ON, whereas the CLK signal is not 
present when PHY 126 is in a power-down mode. During a power-down mode, the 

20 Clock_Enable signal at node 1208 is LOW. The case in which PHY 126 is powered ON 
is considered first. 

With PHY 126 powered ON, the Clock_Enable signal is HIGH, so that node is 
1216 is LOW. The inputs to AND gate 1218 are the current, first, and second unit 
delayed samples of the Reset/Sync signal at node 1214. The particular embodiment 
25 disclosed in Fig. 12b applies to the case in which a Reset signal is HIGH for at least three 
CLK cycles. D flip-flops 1204 and 1206 are edge-triggered flip-flops so that the Reset 
signal at node 1220 will be HIGH only if the Reset/Sync signal at node 1214 is held 
HIGH for at least three CLK cycles, thus indicating that PHY 126 is to be reset. 

With PHY 126 in a power-down mode, Clock_Enable is LOW and D flip-flops 
30 1204 and 1206 are not clocked. Spike filter 1224 filters out noise spikes so as to prevent 
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false resets. When the Reset/Sync signal at node 1214 is held HIGH, node 1216 is 
brought HIGH so that PHY 126 is reset. 

Many other embodiments may be utilized to separate the Sync and Reset signals 
from the Reset/Sync signals. These embodiments make use of the characteristic that the 
5 Reset signal is HIGH for at least n CLK cycles, where n > 2 , so that PHY 126 is reset 
when the Reset/Sync signal is HIGH for n CLK cycles. Other tapped-delay lines may be 
employed to observe when the Reset/Sync signal is HIGH for n CLK cycles, or a finite 
state machine may be employed. 

In some cases PHY 126 may not be connected to MAC 124, or if MAC 124 is 

10 capable of having more than one PHY connected, then there may not be the maximum 
number of PHYs connected. A PHY may be detected as in previously described 
embodiments that determine the number of active pins or ports. For example, for the case 
in which MAC 124 may be connected to one PHY, the RxD[0] pin, the first receive data 
pin, may be sampled as shown in Fig. 10 to determine if it is brought HIGH or LOW 

15 during reset. If it is HIGH, then no PHY is connected, whereas if it is LOW, then a PHY 
is connected. 

Referring back to the computer system of Fig. 1, CPU 102 is under control of the 
operating system (OS), and the OS must load the correct driver software for the specific 
PHY connected to MAC 124. This is facilitated by storing in EEPROM 120 information 

20 related to various PHYs that may be connected to MAC 124. An internal register 140 in 
PHY provides an indirect pointer to a data structure (or structures) in EEPROM 120 
providing the necessary information needed to load the proper driver for PHY 126. 
Chipset 130 may load the data structure into an internal register which is read by the OS 
so that the proper driver is loaded. The loading of the necessary data structure is 

25 independent of loading BIOS stored in memory 112. 

After MAC 124 sends a Reset signal to PHY 126, MAC 124 and PHY 126 each 
exchange an identification word. For one embodiment, the identification word for PHY 
126 is exchanged over one RxD pin, e.g., the RxJD[0] pin, and the identification word 
for MAC 124 is exchanged over one Tx_D pin, e.g., the Tx_D[0] pin. Each identification 

30 word includes a one-bit wide field, PDE (Power-Down Enable), to indicate whether a 
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power-down mode is supported. If both of the MAC identification and PHY 
identification words have the PDE field set, then the power down mode is supported. 

A power-down request is activated by MAC 124. As described earlier, the MtP 
word in Fig. 6 for Tx_EN = 0 has the PHY_PD field in bit position 3. A power-down 
request is indicated when PHY__PD is set for two consecutive MtP words with Tx_EN = 
0. When the power-down mode is requested, PHY 126 may be in the process of sending 
data frames on data link 128. In such cases, if the power-down mode is requested by 
MAC 124, then PHY 124 may respond immediately and stop transmission of a data 
frame currently in progress. Or, PHY 126 may complete transmission of the current data 
frame before powering down. During power-down, the frequency of the CLK signal is 
reduced to save power. Also, during power-down PHY 126 may provide link information 
to MAC 124 so that MAC 124 may determine whether to bring PHY 126 out of power- 
down. To request PHY 126 to power-up, MAC 124 sets the field PHY_PD opposite to 
the value indicating a power-down request. 
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I claim: 



1 . A PHY to provide data to a MAC via PHY-to-MAC words and to receive data 
and commands from the MAC via MAC-to-PHY words, the PHY comprising: 

at least one PHY-to-MAC port to provide signals indicative of the PHY-to-MAC 

words; 

at least one MAC-to-PHY port to receive signals indicative of the MAC-to-PHY 
words; and 

a register to store a pointer to a memory location so as to provide identification 
information about the PHY. 

2. The PHY as set forth in claim 1, further comprising at least one Reset/Sync port 
to receive a signal to provide synchronization so that the PHY-to-MAC words and MAC- 
to-PHY words are synchronized into pairs, wherein a pair comprises one MAC-to-PHY 
word and one PHY-to-MAC word. 

3 . A MAC to provide data and commands to a PHY via MAC-to-PHY words and to 
receive data from the PHY via PHY-to-MAC words, the MAC comprising: 

at least one MAC-to-PHY port to provide signals indicative of the MAC-to-PHY 

words; 

at least one PHY-to-MAC port to receive signals indicative of the PHY-to-MAC 
words; wherein the at least one PHY-to-MAC port receives a signal indicative of a 
pointer to a memory location so as to provide identification information about the PHY. 
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4. The MAC as set forth in claim 3, further comprising at least one Reset/Sync port 
to provide a signal to synchronize the PHY-to-MAC words and MAC-to-PHY words into 
pairs, wherein a pair comprises one MAC-to-PHY word and one PHY-to-MAC word. 

5. A chipset comprising: 

a MAC to provide data and commands to a PHY via MAC-to-PHY words and to 
receive data from the PHY via PHY-to-MAC words, wherein the MAC comprises: 

at least one MAC-to-PHY port to provide signals indicative of the MAC- 
to-PHY words; and 

at least one PHY-to-MAC port to receive signals indicative of the PHY-to- 
MAC words; wherein the at least one PHY-to-MAC port receives a signal indicative of a 
pointer to a memory location so as to provide identification information about the PHY. 

6. The chipset as set forth in claim 5, further comprising at least one Reset/Sync port 
to provide a signal to synchronize the PHY-to-MAC words and MAC-to-PHY words into 
pairs, wherein a pair comprises one MAC-to-PHY word and one PHY-to-MAC word. 

7. The chipset as set forth in claim 5 further comprising a register, wherein the 
chipset loads the identification information into the register. 
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8. The chipset as set forth in claim 7, further comprising at least one Reset/Sync port 
to provide a signal to synchronize the PHY-to-MAC words and MAC-to-PHY words into 
pairs, wherein a pair comprises one MAC-to-PHY word and one PHY-to-MAC word. 

9. A computer system comprising: 
a first memory device; 

a MAC; 

a PHY to provide data to the MAC via PHY-to-MAC words and to receive data 
and commands from the MAC via MAC-to-PHY words, the PHY comprising: 

at least one PHY-to-MAC port to provide signals indicative of the PHY- 
to-MAC words; 

at least one MAC-to-PHY port to receive signals indicative of the MAC- 
to-PHY words; and 

a register to store a pointer to a memory location in the first memory 
device so as to provide identification information about the PHY. 

10. The computer system as set forth in claim 9, wherein the MAC further comprises 
a register to store the identification information. 

1 1 . The computer system as set forth in claim 9, further comprising: 
a processor; 

system memory; 
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secondary memory to store a device driver for the PHY; wherein the processor 
loads the device driver from the secondary memory into system memory based upon the 
identification information. 

12. The computer system as set forth in claim 1 1, wherein the MAC further comprises 
a register to store the identification information. 

13. The computer system as set forth in claim 1 1, further comprising a second 
memory device to store BIOS, wherein the processor loads the device driver 
independently of loading the BIOS. 

14. The computer system as set forth in claim 12, further comprising a second 
memory device to store BIOS, wherein the processor loads the device driver 
independently of loading the BIOS. 

15. The computer system as set forth in claim 14, further comprising; 
a system bus; and 

a chipset in communication with the system bus, wherein the MAC is integrated 
with the chipset. 
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Abstract 

A word-based interface between a MAC and a PHY, allowing for variable pin 
counts, variable PHY and MAC data speeds, and variable numbers of connected PHYs. 
The word-based interface allows for the PHY to provide PHY-to-MAC words to the 
MAC, and for the MAC to provided MAC-to-PHY words to the PHY, where the PHY-to- 
MAC words are synchronized with the MAC-to-PHY words. Data and commands are 
provided in fields of the words, and may be time multiplexed over the interface. Circuits 
within the MAC and PHY allow for the MAC to detect if a PHY is present, the number 
of active pins, and the number of PHYs connected. The reset and synchronization signals 
are integrated into a single reset/sync signal. Identification data is exchanged between the 
MAC and PHY so that the proper device driver for the PHY may be loaded 
independently of the BIOS. 
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